## 程序代期被做破漏程辅导

- 3. Put your solute the property into implementation subcircuit
- 4. Do not renam substitution substitution substitution substitution automatically substitution automatically substitution substitution
- 5. Do not chang the implementation subcircuit from what it is set as. Doing so will the tester when you submit.
  - a. That is this field right here



- 6. Do not move the fine inside of the imperior taking subcircuit as that affects the appearance of the circuit on the outside as you saw in discussion. Doing so will cause you to automatically fail the tester when you submit.
  - a. If you want to "move the pins" instead connect tunnels to the pins and move the tunnels around. LUCOTCS . COTT
- 7. Do not name any of the subcirucits in your solution main. Doing so will cause you to automatically fail the tester when you submit.
- 8. You **can** create as many other subcircuits as you want in your solution. Just make sure your solution ends up in the implementation subcircuit

## Update Your Version of Logisim Evolution

A new release of Evolution has come out since class started. We are upgrading to the new version because it fixes a bug that prevented loading memory image files. We need this feature so the update is mandatory. Again you find the <u>version of Logisim Evolution you need</u> on the class Google Drive.

## Warning!!! Warning!!! 程序代写代做 CS编程辅导 This project will take a long time. Expect to spend at least 30 hours on it.



For all problems in th y only use

- All of the com
- All of the com **EXCEPT** for Controlled Buffer, Controlled Inverter,
- All of the components un
- All of the components under Arithmetic
- All of the components under Memory **EXCEPT** for **RAM**, **ROM**, and **Random** Generator Unless a problem specifies other visat: CSTUTOTCS

## Problem Spacificationent Project Exam Help

Implement a Cache that meets the specifications below.

# Cache Specifications tutores @ 163.com

| Parameter QQ: 749389            | Value 6                           |
|---------------------------------|-----------------------------------|
| CPU Address                     | 10 bits                           |
| Cache Data Size https://tutor   | <mark>C&amp;</mark> ₽ <b>@O</b> M |
| Number of Sets                  | 2                                 |
| Number of Ways (Blocks per Set) | 3                                 |
| Block Size                      | 4 Bytes                           |
| Write Policy                    | Write Back                        |
| Eviction Policy                 | LRU                               |

## Inputs

| Input Pin | Size (bits) | Description |
|-----------|-------------|-------------|
|-----------|-------------|-------------|

| CpuAddress    | 10/学 序 | The address the CPU wants to read from of witers                  |
|---------------|--------|-------------------------------------------------------------------|
| CpuRead       | 1 bit  | 1 If the CPU wants to Read and 0 otherwise                        |
| CpuWrite      |        | 1 if the CPU wants to Write and 0 otherwise                       |
| CpuWriteValue | 8      | the CPU wants to Write. Will only have a ul value is CpuWrite = 1 |
| LineFromMem   | 32     | nts of the block you requested to read from memory                |

All of the inputs will o **SINGLE** clock cycle that your Cache says it is Ready. This means that you will have to save your inputs if you need them beyond that first clock cycle.

The only **exception** to this scine From Mem. It will be valid as long as you say you want to read from memory. If you aren't reading from memory Line From Mem will be EEE... and Red (an Error). Don't worry about this. It is normal behavior. As soon as your request to read from memory it will be the your adjusted that the project Exam Help

## Outputs Email: tutorcs@163.com

| Output Pin | Size (in bits) | Description 7.40200.47.6                                                                                                                                                                                  |
|------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ready      | https          | 1 if your cache is ready to start a new request. If you are ready to start a new request it means you must have finished the old request. So at this point in time, your output will be checked torcs.com |
| DidContain | 1 bit          | 1 if your Cache contained the value the CPU asked for and 0 otherwise. Checked when Ready == 1                                                                                                            |
| ByteRead   | 8 bits         | The value at the address the CPU requested to read. Checked when Ready == 1 and the last request the CPU made was a read.                                                                                 |
| MemAddress | 8 bits         | The address of the <b>block</b> you want to read from memory or the address of the <b>block</b> that you want to write Line2Memory back to.                                                               |
| MemRead    | 1 bit          | 1 if you want to read the <b>block</b> at MemAddress and 0 otherwise.                                                                                                                                     |
| MemWrite   | 1 bit          | 1 if you want to write Line2Mem to MemAddress and 0 otherwise.                                                                                                                                            |

## Why is MemA( stead of 10?

Our Memory is going each block has an acblock to memory in a be pretty easy to figure pick out the byte with

sable instead of Byte Addressable. This means that n byte. This enables you to read a block from/write a nich should help simplify your design a little. It should rop to form MemAddress. Hint: it is bits that help you

## When are outpws steeked? cstutorcs

- DidContain: At the end of every operation once your circuit becomes **Ready**.
- ByteRead: At the end of a read operation once your circuit becomes **Ready**.
- MemRead: Whenever you reach from memorp it increments the Misson member Help

Timing Restrictions Email: tutorcs@163.com

Your circuit must be able to complete a Read/Write request within 10 clock cycles. If you take longer than 10 clock cycles the tester will automatically advance to the next case. This will cause your Cache to start to "desync" from the tester and so will get everything wrong if you are taking too long. You can certainly finish in less than 10 clock cycles, I only took 7 but I've seen students get as low as 2.

## https://tutorcs.com

## **Testing**

- 1. Open the grading circuit
- Click on the Cache folder and select reload library
  - a. Double-check that your updates are visible inside of the grader. If your changes don't show up, close your solution circuit and try reloading again. If the changes still fail to show up, close the grader and reopen it and then reload the library.
- Open the subcircuit named CheckerCirc and
  - a. Right-click the ROM inside of it
  - b. Select Load Image
  - c. Select one of the provided files that ends in sol.txt.
    - i. Eample: seg read1 seg mem sol.txt
- 4. Open the subcircuit named InputGeneratorCirc and
  - a. Right-click the ROM inside of it
  - b. Select Load Image

- c. Select the corresponding input file that matches with the solution file. This will be the file that shares its name with the best part of the polition f
  - Example: seg read1.txt
- Go back to the main subcircuit

  - emory file that matches with the solution file. This will me with the second part of the solution file.

**ELOAD the RAM!** The RAM is the only one that has Anytime your reset a to be reloaded. The ROM's will maintain the last value you put in them.

At the bottom of the the main circuit you will find probes that show your circuit's inputs, outputs, answers, how many reads voluget correct, now many lines you said you hit, and how many misses(memory reads) you had. This is a good place to look when you are debugging to get a high level overview of what your cache is doing.

Assignment Project Ex If you open the solution files in a text editor you will find what the cor the stats should be for that test case.

#### Email: tutorcs@163.com Testing Order

I recommend running the test cases in the following order

- 1. seq\_read1\_seq\_\_\(\)(en)\_sol/x4493894/6
- 2. seg write1 seg mem sol.txt
- 3. set1 targeted read seg mem sol.txt
- 4. set0\_targeted write\_seg\_mem\_sol.txt
- 5. random0\_seq\_memps\_tw//tutorcs.com
- 6. final test rand mem mem sol.txt.

#### **User Created Tests**

If you want to make your own test, you can use <u>cache test maker.py</u> to create your own tests. It should be fairly easy to follow the documentation inside if you feel like using it.

#### Scoring

Your score is calculated as num correct read values - abs(num correct read value number of reads you got correct) + num correct hits - abs(num correct hits your number of hits) + num correct misses - abs(num correct misses -

your\_number\_of\_misses). Essentially you lose points for every value you are off from the right answers. 程序代写代数 CS编程辅导

## Debugging

To help you with debushow you what your this program at <a href="https:/">https:/</a> find it helpful.

ent, Noah Rose Ledesma, created a program to help loing so you don't have to do it by hand. You can find seLedesma/CacheHitDetector. Give it a star if you

Once you know what is supposed to be happening you have to go back to the ctrl+t and watching everything your circuit is doing to make sure it is doing what you expect it to. This is one of the most time counting property of the counting probest to literally everything so you know what is happening.

# Assignment Project Exam Help What to Submit

A file named Cache. To with your solution in the implementation subcircuit m

#### **Hints**

- Before you standown anything in Logisim make sure you really understand how the Cache should work on both a read and a write. Write out Psuedo Code detailing what should happen. This Psuedo Code should be so detailed that you could write a program that emulates adactio. You need that the complete adaction to correctly implement your cache.
- Make subcircuits for Sets and Ways. Then for each Set or Way you need you can lay down an instance of that subcircuit.
- Speaking of Subcircuits, use lots of them to help keep your circuits neat.
- The bit finder can be a very useful tool in helping you to figure out which way within a set you should be working with.
- Do the data path first and then the control path. You won't know what control signals you need until the data path is built so build that data path first. I ended having about 7 control signals. You may have more or less depending on your design.
- When it comes to data values, it is generally safe to pass the same data value to all of your Sets/Ways. Students are tempted to use Demuxes to "send" the data to the correct Set/Way. This is an incorrect way to think as the Sets/Ways that aren't selected still get a value, it is just 0.
- For control signals, you may need to send them to only a single Set/Way by using a Demux or you may need to send the signal to all Sets/Ways. To figure this out simply,

Your circuit does not have to start out being ready. I needed an initialize state so that I could set the ages of the lines and as such I wasn't ready to begin until after I had passed through a line.

- You can great by just thinking that you will get your value from a set or a line. Obvious the state of the right one, but you can easily select among them by using muxing muxing the state of the correct input by using dmuxes. This will save you are looking the state of the right one gets the correct input by using dmuxes.
- Here are som ade that I made solving the problem. Hopefully you can learn from them
  - Forgot to rename some labels
  - Needed to both add and remove states from my FSM
  - o Mixed up the loof alway with its Age LOTCS
  - Messed up on the aging of lines. I assumed that they would all start with unique values but of course they don't.
    - Ines to 0,7, and 2.
  - Used the wrong Tag bits to when addressing memory on writes.
    - Fix. When writing to memory you should use the Tag bits found in the Line that you will be witting. When bearing from memory you should use the Tag bits from the CpuAddress.

QQ: 749389476

https://tutorcs.com